-
-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(vue-query): mark the watcher as post flush #7942
Conversation
pnpm patch for the one who wants to test it: diff --git a/build/modern/useQueries.js b/build/modern/useQueries.js
index c172ecd85df4646ab4869411725cc028ccc0e7e1..ec584988a4ecb9f24c073eb94a4b5cbc9e8eb255 100644
--- a/build/modern/useQueries.js
+++ b/build/modern/useQueries.js
@@ -81,7 +81,7 @@ function useQueries({
);
state.value = getCombinedResultPersisted();
},
- { flush: "sync" }
+ { flush: "post" }
);
onScopeDispose(() => {
unsubscribe();
|
We deployed this patch to production on Monday and found no issues for the moment. |
☁️ Nx Cloud ReportCI is running/has finished running commands for commit c6443c4. As they complete they will appear below. Click to see the status, the terminal output, and the build insights. 📂 See all runs for this CI Pipeline Execution ✅ Successfully ran 2 targetsSent with 💌 from NxCloud. |
commit: @tanstack/angular-query-devtools-experimental
@tanstack/angular-query-experimental
@tanstack/eslint-plugin-query
@tanstack/query-async-storage-persister
@tanstack/query-broadcast-client-experimental
@tanstack/query-core
@tanstack/query-devtools
@tanstack/query-persist-client-core
@tanstack/query-sync-storage-persister
@tanstack/react-query
@tanstack/react-query-devtools
@tanstack/react-query-next-experimental
@tanstack/react-query-persist-client
@tanstack/solid-query
@tanstack/solid-query-devtools
@tanstack/solid-query-persist-client
@tanstack/svelte-query
@tanstack/svelte-query-devtools
@tanstack/svelte-query-persist-client
@tanstack/vue-query
@tanstack/vue-query-devtools
More templates
|
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #7942 +/- ##
===========================================
+ Coverage 44.64% 71.42% +26.78%
===========================================
Files 187 19 -168
Lines 7090 462 -6628
Branches 1575 119 -1456
===========================================
- Hits 3165 330 -2835
+ Misses 3562 102 -3460
+ Partials 363 30 -333
|
We could potentially remove sync watcher entirely. |
I'm not entirely sure about the implications either. If removing this |
You would also need to override |
Then we could merge that one first and work towards removing all watchers in a follow-up PR/issue. |
I do not think merging this and immediately changing solution in a follow-up is the way to go. |
I might be misunderstanding, but I think we’re talking about different things. This PR is updating a watcher for the |
Could someone review this again? This issue affects all Vue applications using useQueries. It's a significant problem that shouldn't be disregarded. |
As mentioned before i do not think this change should be merged as it will introduce another bug in specific cases where states would not be properly synced up when calling There is a similar PR that handled that for other hooks, and this MR should be adjusted to follow similar pattern. #6043 In that MR you could see additional block that patches |
I have opened a PR(#8443) to address this issue. If there are any areas where I may have overlooked something, please kindly let me know. Thank you! |
Hey there! 👋🏻
This PR changes the watcher mode for
useQueries
fromsync
topost
.The change is needed to avoid having the watcher run during component unmount.
Note
This change will probably be needed on
useBaseQuery
, but I haven't tested it yet.Related VueJS issues:
watch
runs while the component is being unmounted vuejs/core#7030undefined
posva/unplugin-vue-router#86Currently, using the route params to define some query params triggers a new fetch when leaving a route.
For example, let's say we have the following code that runs when we are on
/players/:id
./players
to/players/1
, TanStack Query will trigger a fetch for Player1
(expected)./players/1
to/players
, TanStack Query will trigger a fetch for Playerundefined
(unexpected)./players/1
to/transfers/12345
, TanStack Query will trigger a fetch for Player12345
(unexpected).This is due to the watcher running when the page changes.
I haven't created an easy and sharable reproduction. Let me know if it is needed.